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DETAILED ACTION 

1 . Claims 1-30 are pending in this application. 

Claim Rejections - 35 USC § 103 

2. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

3. Claims 1-6 and 8-10 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over U.S. Pat. No. 5,261,097 to Saxon in view of U.S. Pat. No. 
5,911,066 to Williams et al. 

4. As to claim 1 , Saxon teaches a computer-implemented method for passing a 
message from a first thread of execution in a process to a second thread of execution in 
the process (Col. 3 Ln. 7 - 15, Ln. 60 - 67, Col. 4 Ln. 1 - 28), the first thread being 
adapted to interpret a block of source code (Col. 3 In. 15 - 19, Ln. 60 - 67) and the 
second thread having a queue for holding messages (Col. 4 Ln. 16 - 28). 

5. Saxon is silent with reference to the method comprising: placing, by the first 
thread a reference to the message in the queue of the second thread wherein the 
reference is usable by the second thread to access the message. 
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6. Williams teaches the method comprising: placing, by the first thread a reference 
to the message in the queue of the second thread wherein the reference is usable by 
the second thread to access the message (Col. 17 Ln. 58 - 67). 

7. It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to combine the teachings of Williams and Saxon because the 
teaching of Williams would improve the system of Saxon by providing means for 
transferring data (Col. 17 Ln. 58 - 67). 

8. As to claim 2, see the rejection of claim 1 . 

9. As to claim 3, Williams teaches the method of claim 1 ; further comprising: 
receiving a reference to the second thread's queue and using the reference to the 
second thread's queue to perform the placing step (Col. 17 Ln. 58 - 67). 

1 0. As to claim 4, Williams teaches the method of claim 1 , wherein the first thread 
has a queue, the method further comprising: passing, to the second thread, a reference 
to the first thread's queue to allow the second thread to send messages to the first 
thread queue (figure 8 (GetData) Col. 8 Ln. 51 - 67, Col. 9 Ln. 1 - 5). 

11. As to claim 5, Williams teaches the method of claim 1 ; further comprising: 
sending a signal to the second thread to indicate that a message has been sent to the 
second thread ("...return_value..." Col. 8 Ln. 46 - 48). 
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12. As to claim 6, Williams teaches the method of claim 5, wherein the signal is sent 
via a platform independent object since the invention is practiced using COM (Col. 4 Ln. 
31 - 37). 

1 3. As to claim 8, Saxon teaches a method for passing intraprocess messages 
between scripting threads in a process (Col. 3 Ln. 7 - 15, Col. 3 Ln. 60 - 67, Col. 1 - 
15), the method comprising: creating a first scripting thread of execution (Col. 3 Ln. 60 - 
67), creating a queue for the first scripting thread (Col. 4 Ln. 16 - 28) and creating a 
second scripting thread of execution (Col. 3 Ln. 60 - 67). 

14. Saxon is silent with reference to passing to the second scripting thread, a 
reference to the first scripting thread's queue for use by the second scripting thread to 
send messages to the first scripting thread. 

1 5. Williams teaches passing to the second scripting thread, a reference to the first 
scripting thread's queue for use by the second scripting thread to send messages to the 
first scripting thread (figure 8 (GetData) Col. 8 Ln. 18 - 67, Col. 9 Ln. 1 - 5). 

1 6. It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to combine the teachings of Williams and Saxon because the 
teaching of Williams would improve the system of Saxon by providing means for 
retrieving data (Col. 8 Ln. 18 - 20). 

1 7. As to claim 9, see the rejection of claim 8. 
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18. As to claim 10, Saxon teaches the method of claim 8; further comprising: creating 
a queue for the second scripting thread (Col. 4 Ln. 16 - 28), while Williams teaches 
passing, to the first scripting thread, a reference to the queue of the second scripting 
thread for use by the first scripting thread to send messages to the second scripting 
thread (Col. 9 Ln. 6 - 34). 

19. Claims 14-16,18-26 and 27 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over U.S. Pat. No. 6,141,793 to Bryant et al. in view of U.S. Pat. No. 
5,261,097 to Saxon et al. 

20. As to claim 14, Bryant teaches a method for compiling a program having a 
plurality of sections (Col. 6 Ln. 47 - 55), the method comprising: creating a scripting 
thread for compiling each section (figure 8 Col. 6 Ln. 23 - 46). 

21 . Bryant is silent with reference to creating a control thread to asynchronously 
communicate with each of the scripting threads so that commands can be issued from 
the control thread to the scripting threads in parallel. 

22. Saxon teaches creating a control thread to asynchronously communicate with 
each of the scripting threads so that commands can be issued from the control thread to 
the scripting threads in parallel (Col. 3 L 61 - 67, Col. 4 Ln. 1 - 28). 
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23. It would have been obvious to one of ordinary skill in the art at the time invention 
was made to combine the teachings of Saxon and Bryant because the teaching of 
Saxon would improve the system of Bryant by allowing synchronization of thread 
execution (Col. 4 Ln. 3 - 6). 

24. As to claim 15, see the rejection of claim 14. 

25. As to claim 16, Saxon teaches the method of claim 14; further comprising: at the 
control thread, sending updates to a user interface (Col. 4 Ln. 30 - 40) and processing 
commands from the user interface in parallel with asynchronously sending commands 
to the scripting threads (Col. 3 Ln. 64 - 67). 

26. As claim 18, Bryant teaches a system for compiling a program having a plurality 
of sections (Col. 6 Ln. 47 - 55), the system comprising: a computer (figures 2/3), a 
plurality of scripting threads executing on the computer (Server Application 120/Cgi-bin 
Application 140/Perl Server Process 160 Col. 4 Ln. 45 - 67), wherein each section of 
the program is compiled under the direction of a scripting thread of the plurality (figures 
7/8 Col. 5 Ln. 63 - 67, Col. 6 Ln. 1 - 46) and a control thread executing on the 
computer for coordinating the activity of the scripting threads by communicating 
asynchronously with the scripting threads (Perl Server 160 Col. 4 Ln. 51 - 61 , figure 8 
Col. 23 - 35). Also see the rejection of claim 14. 
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27. As to claim 19, Bryant teaches the system of claim 18, further comprising: a 
means for allowing the control thread to communicate asynchronously with the scripting 
threads ("...pipe..." Col. 4 Ln. 56 - 61 , Col. 6 Ln. 23 - 37). 

28. As to claim 20, Bryant teaches the system of claim 18; further comprising: a 
plurality of queues, wherein each queue is associated with a scripting thread of the 
plurality of scripting threads, and wherein each queue is adapted to receive messages 
from the control thread ("...next pipe..." Col. 6 Ln. 23 - 37). 

29. As to claim 21 , Bryant teaches the system of claim 18; further comprising: a 
means for sending a signal from the control thread to at least one of the plurality of 
scripting threads to alert the scripting thread whenever a message is sent to the 
scripting thread ("...receives..." Col. 4 Ln. 56 - 67, figure 9 Col. 6 Ln. 56 - 59). 

30. As to claim 22, Bryant teaches the system of claim 18; further comprising: a 
script engine executing on the computer (figure 4 Col. 4 Ln. 35 - 44), wherein the script 
engine interprets scripting language commands for each of the plurality of scripting 
threads (Col. 6 Ln. 39 - 40) and provides a means for sending a signal from the control 
thread to at least one of the plurality of scripting threads to alert the scripting thread 
whenever a message is sent to the scripting thread ("...receives..." Col. 4 Ln. 56 - 67, 
figure 9 Col. 6 Ln. 56-59). 
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31 . As to claim 23, Bryant teaches the system of claim 18, wherein the computer is a 
first computer, the system further comprising: at least one second computer in 
communication with the first computer, wherein at least one of the scripting threads 
executes on the second computer (figure 4 Col. 35 - 67). 

32. As to claim 24, Bryant teaches the system of claim 23; further comprising: a 
network link for enabling the first and second computers to communicate with one 
another (figure 2 Col. 3 Ln. 55 - 65), a means for allowing the scripting thread executing 
on the second computer to communicate across the network link with the first computer 
(figure 4 Col. 4 Ln. 35 -55). 

Although Bryant does not teach the control thread as executing on the first computer, 
one of ordinary skill in the art would know to implement the system to include the control 
thread as executing on the first computer since the server system of Bryant can reside 
on any physical machine (Col. 4 Ln. 23 - 26). 

33. As to claim 25, Saxon teaches the system of claim 18, further comprising: a user 
interface, wherein the control thread is operable to update the user interface without 
having to wait for the scripting threads to act on messages sent to them by the control 
thread ("...p1 pn..." Col. 4 Ln. 16 - 57). 

34. As to claim 26, Bryant teaches a system for compiling a program having a 
plurality of sections (Col. 6 Ln. 47 - 55), the system comprising: a server computer 
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(figure 4 Col. 4 Ln. 35 - 55); a control thread executing on the server computer (figure 8 
Col. 6 Ln. 23 - 37), a plurality of client computers (figure 4 Col. 4 Ln. 35 - 55), wherein 
each client computer compiles a section of the plurality of sections (Server Application 
120/Cgi-bin Application 140/Perl Server Process 160 Col. 4 Ln. 45 - 67), and wherein 
the client computers are in communication with the server computer, and a plurality of 
scripting threads executing on the server computer (figure 4 Col. 4 Ln. 35 - 55, Col. 6 
Ln. 23 - 55), wherein each scripting thread directs the compiling activity of a client 
computer of the plurality of client computers (figure 4 Col. 4 Ln. 35 - 55), and wherein 
the control thread sends messages asynchronously to each of the plurality of scripting 
threads to coordinate their activities (figure 8 Col. 6 Ln. 23 - 37). Also see the rejection 
claim 14. 

35. As to claim 27, Bryant teaches the system of claim 26, wherein the control thread 
sends messages asynchronously to each of the plurality of scripting threads to 
coordinate their activities, thereby resolving interdependences among different sections 
of the program that are being compiled ("...pipe..." Col. 4 Ln. 56-67). 

36. Claims 7,11-13 are rejected under 35 U.S.C. 103(a) as being unpatentable 
over U.S. Pat No. 5,261,097 to Saxon in view of U.S. Pat. No. 5,911,066 to Williams 
et al. as applied to claim 1 above, and further in view of U.S. Pat. 6,728,722 B1 to 
Shaylor. 
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37. As to claim 7, Saxon as modified by Williams is silent with reference to the 
method of claim 1 ; further comprising: defining a message object for holding the 
message; and inserting the message into the message object, wherein the reference 
placed in the second thread's queue is a reference to the message object. 

38. Shaylor teaches the method of claim 1 ; further comprising: defining a message 
object for holding the message, and inserting the message into the message object 
(Col. 18 Ln. 26 - 43), wherein the reference placed in the second thread's queue is a 
reference to the message object ("...pointer..." Col. 13 Ln. 57 - 67, Col. 14 Ln. 1 - 3). 

39. It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to combine the teaching of Shaylor, Saxon and Williams because 
the teaching of Shaylor would improve the system of Saxon as modified by Williams by 
reducing the amount data to be transferred in a message passing system (Shaylor Col. 
13 Ln. 63-67). 

40. As to claim 1 1 , see the rejection of claim 7. 

41 . As to claim 12, Williams teaches the method of claim 1 1 ; further comprising: 
sending a signal from the first scripting thread to the second scripting thread to indicate 
to the second scripting thread that a new message has been sent to the second 
scripting thread ("...return^value..." Col. 29-32). 
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42. As to claim 1 3, Shaylor teaches the method of claim 1 1 , wherein in response to 
the message further comprising: inserting a flag in the message object to indicate that it 
is being responded to and placing a reference to the message object in the queue of the 
first scripting thread (Col. 17 Ln. 54 - 62). 

43. Claim 17 is rejected under 35 U.S.C. 103(a) as being unpatentable over U.S. 
Pat. No. 6,141,793 to Bryant et al. in view of U.S. Pat. No. 5,261,097 to Saxon et al. 
as applied to claim 14 above, and further in view of U.S. Pat. 6,728,722 B1 to 
Shaylor. 

44. As to claim 17, Bryant as modified by Saxon is silent with reference to the 
method of claim 14, further comprising: creating a queue for the control thread and 
passing, to at least one of the scripting threads, a reference to the control thread's 
queue for use by the scripting thread to send messages to the control thread. 

45. Shaylor teaches the method of claim 14, further comprising: creating a queue for 
the control thread (Col. 18 Ln. 26 - 43) and passing, to at least one of the scripting 
threads, a reference to the control thread's queue for use by the scripting thread to send 
messages to the control thread ("...pointer..." Col. 13 Ln. 57-67, Col. 14 Ln. 1 -3). 

46. It would have been obvious to one of ordinary skill in the art at the invention was 
made to combine the teachings of Shaylor, Bryant and Saxon because the teaching of 
Shaylor would improve the system of Bryant as modified by Saxon by reducing the 
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amount data to be transferred in a message passing system (Shaylor Col. 13 Ln. 63 - 
67). 

47. Claims 28,29 and 30 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over U.S. Pat. No. 6,141,793 to Bryant et al. in view of U.S. Pat. No. 
5,261,097 to Saxon et al. as applied to claim 26 above, and further in view of U.S. 
Pat. 5,91 1 ,066 to Williams et al. 

48. As to claim 28, Bryant teaches the system of claim 26; further comprising: a one 
or more control thread queues associated with the control thread (Col. 4 Ln. 56 - 62). 

49. Bryant as modified by Saxon is silent with to reference to a plurality of scripting 
thread queues, wherein each scripting thread queue is associated with a scripting 
thread of the plurality of scripting threads, and wherein the control thread has a 
reference to each scripting thread queue, and wherein each scripting thread has a 
reference to at least one control thread queue that is associated with the scripting 
thread, thereby enabling the control thread to put one or more of the messages in each 
scripting thread queue and each scripting thread to put response messages in the 
associated queue of the control thread. 

50. Williams teaches a plurality of scripting thread queues ("...media..." Col. 8 Ln. 35 
- 67), wherein each scripting thread queue is associated with a scripting thread of the 
plurality of scripting threads ("...client..." Col. 8 Ln. 35 - 67), and wherein the control 
thread has a reference to each scripting thread queue ("...pformatetc parameter..." Col. 
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8 Ln. 35 - 40), and wherein each scripting thread has a reference to at least one control 
thread queue that is associated with the scripting thread, thereby enabling the control 
thread to put one or more of the messages in each scripting thread queue and each 
scripting thread to put response messages in the associated queue of the control thread 
("...GetData.../...GetDataHere..." Col. 35-67, Col. 9 Ln. 1-34). 

51 . It would have been obvious to one of ordinary skill in the art at the time the 
invention was made to combine the teachings of Bryant, Saxon and Williams because 
the teaching of Williams would improve the system of Bryant and Saxon by providing 
means for retrieving and transferring data. 

52. As to claim 29, Bryant teaches the system of claim 26; further comprising: at 
least one script stored on the server computer, wherein the script contains instructions 
for directing the compilation of the program (Server Application 120/Cgi-bin Application 
140 Col. 4 Ln. 45 - 67) and a script engine executing on the server computer to 
interpret the script, the script engine having an inter-thread signaling mechanism (Perl 
Server Process 160 Col. 4 Ln. 45 - 67), wherein the control thread uses signaling 
mechanism to alert a scripting thread of the plurality of scripting threads whenever the 
control thread has sent a message to the scripting thread (figure 8 Col. 6 Ln. 23 - 67). 

53. As to claim 30, Bryant teaches the system of claim 26, wherein the control 
thread sends messages asynchronously to each of the plurality of scripting threads to 
coordinate their activities, thereby resolving interdependencies among different sections 
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of the program that are being compiled, the system further comprising: a plurality of 
control thread queues associated with the control thread; a plurality of scripting thread 
queues, wherein each scripting thread queue is associated with a scripting thread of the 
plurality of scripting threads ("...pipes..." Col. 6 Ln. 23 - 38), and at least one script 
stored on the server computer, wherein the script contains instructions for directing the 
compilation of the program (Server Application 120/Cgi-bin Application 140 Col. 4 Ln. 
45 - 67) and a script engine executing on the server computer to interpret the script, the 
script engine having an inter-thread signaling mechanism (Perl Server Process 160 Col. 
4 Ln. 45 - 67), wherein the control thread uses signaling mechanism to alert a scripting 
thread of the plurality of scripting threads whenever the control thread has sent a 
message to the scripting thread (figure 8 Col. 6 Ln. 23 - 67), while Williams teaches the 
control thread having a reference to each scripting thread queue ("...pformatetc 
parameter..." Col. 8 Ln. 35 - 40) and wherein each scripting thread has a reference to a 
corresponding control thread queue of the plurality of control thread queues, thereby 
enabling the control thread to put one or more of the messages in each scripting thread 
queue and each scripting thread to put response messages in its corresponding control 
thread queue ("...GetData.../...GetDataHere..." Col. 35-67, Col. 9 Ln. 1 -34). See the 
rejection of claim 28. 

Response to Arguments 

54. Applicant's arguments with respect to claims 1-30 have been considered but are 
moot in view of the new ground(s) of rejection. 
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Conclusion 



Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Charles E Anya whose telephone number is (703) 305- 
341 1 . The examiner can normally be reached on M-F (8:30-6:00) First Friday off. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, An Meng-Ai can be reached on (703) 305-9678. The fax phone number for 
the organization where this application or proceeding is assigned is 703-872-9306. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). 



Charles E Anya 
Examiner 
Art Unit 2126 
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